Nedeterministički konačni automat
U teoriji izračunljivosti, nedeterministički konačni automat (NKA) (još i nedeterministički konačni stroj[1]) je konačni automat u kojem za svaki par stanja i ulaznog znaka (simbola) može postojati nekoliko mogućih sljedećih stanja.
NKA obrađuje niz ulaznih znakova. Za svaki ulazni znak obavlja prijelaz u novo stanje sve dok svi ulazni znakovi nisu obrađeni.
Zovemo ga nedeterminističkim zato jer se može dovesti u situaciju da postoje višestruki prijelazi iz trenutnog stanja koristeći isti znak. Za ε-NKA je također moguć prijelaz u novo stanje bez čitanja ulaznog znaka uopće. Na primjer, ako je neki fiktivni ε-NKA trenutno u stanju 1, a sljedeći ulazni znak jest a, on može preći u stanje 2 bez da obradi ijedan ulazni znak, kao i ući u stanje 3 čitanjem znaka a. NKA ne može odrediti koji je korektan prijelaz koji treba obaviti, te stoga ulazi u oba stanja.
Promjene stanja ε-NKA, a da se pri tome ne pročita ulazni znak, zovemo epsilon-prijelazi ili lambda-prijelazi. Obično se označavaju grčkim slovima ε ili λ.
Kada NKA pročita sve znakove ulaznog niza, on prihvaća niz ako i samo ako postoji neki slijed prijelaza koje može načiniti a koji će ga dovesti u prihvatljivo stanje. Shodno tome, ne prihvaća (odbija) niz znakova ako bez obzira koje izbore učini prilikom prijelaza u neki element skupa od više stanja, neće završiti u nekom od prihvatljivih stanja.
Nedeterministički konačni automat (NKA) se formalno definira kao uređena petorka, , koju čini:
- konačni skupa stanja ()
- konačni skup ulaznih znakova zvan ulazna abeceda ()
- funkcija prijelaza ()
- početno (ili inicijalno) stannje ()
- istaknuti skup stanja kojeg zovemo skup prihvatljivih (ili finalnih) stanja ()
pri čemu je partitivni skup (skup svih podskupova) skupa , prazni niz, a ulazna abeceda
Neka je M NKA takav da M = , i X je niz znakova nad abecedom . M prihvaća niz X ako postoji i reprezentacija niza X oblika , i slijed prijelaza stanja koji zadovoljava sljedeće uvjete:
- za
Stroj započinje rad u proizvoljnom početnom stanju te potom čita niz znakova svoje ulazne abecede. Automat koristi relaciju prijelaza T da odredi sljedeće stanje koristeći trenutno stanje te znak upravo pročitan ili prazni niz (u slučaju ε-prijelaza). Međutim, sljedeće stanje NKA ne ovisi samo o trenutnom ulaznom događaju (tj. trenutno pročitanom znaku), već i o proizvoljnom broju narednih ulaznih događaja. Sve dok se ti sljedeći ulazni događaji ne dogode (tj. znakovi se ne pročitaju), nije moguće odrediti stanje u kojem se stroj nalazi. Ako se po završetku čitanja ulaznog niza automat nalazi u prihvatljivom stanju, kažemo da NKA prihvaća niz, inače kažemo da ga ne prihvaća (odbija).
Skup svih nizova znakova koje NKA prihvaća zovemo jezikom koji NKA prihvaća. Taj jezik je regularni jezik.
Za svaki NKA može biti konstruiran istovjetni DKA, tj. DKA koji prihvaća isti jezik. Stoga je moguće obaviti konverziju već postojećeg NKA u DKA u svrhu implementiranja (možebitno) jednostavnijeg stroja. Takva konverzija može dovesti do eksponencijalnog rasta u broju potrebnih stanja stroja.
Postoji mnogo načina za ostvarenje NKA:
- Konvertiraj u istovjetni DKA. U nekim će slučajevima doći do eksponencijanog rasta u veličini automata (posebice broju potrebnih stanja) a time i pomoćnog prostora proporcionalnog broju stanja NKA (s obzirom da pohrana vrijednosti stanja zahtijeva najviše jedan bit za svako stanje NKA).
- Održavaj podatkovnu strukturu skup (konačni asocijativni kontejner bez ponavljanja vrijednosti) koja će sadržavati sva stanja u kojima stroj trenutno može biti. Prilikom čitanja posljednjeg ulaznog znaka, ukoliko je jedno od stanja konačno stanje, stroj prihvaća niz znakova. U najgorem slučaju, ovo može zahtijevati pomoćni prostor veličine proporcionalne broju stanja NKA; ako podatkovna struktura skup koristi točno jedan bit po stanju NKA, ovo ostvarenje je istovjetno prethodnom.
- Stvaramo višestruke kopije. Za svaku odluku o grananju u n stanja, NKA kreira do kopija stroja. Svaka kopija ulazi u odvojeno stanje. Ako se, prilikom čitanja posljednjeg ulaznog znaka, barem jedna kopija NKA nalazi u prihvatljivom stanju, NKA prihvaća ulazni niz znakova. (Ovo ostvarenje također zahtijeva linearni prostor za pohranu s obzirom na broj stanja NKA, budući da može biti postojati po jedan stroj za svako stanje NKA).
- Eksplicitno propagiraj pojedine znakove kroz prijelaznu strukturu NKA i zabilježi kadgod znak dosegne prihvatljivo stanje. Ovo je ponekad korisno kad NKA treba enkodirati dodatni kontekst o događajima koji su potaknuli prijelaz. (Za programsko ostvarenje ove tehnike koja prati reference na objekt pogledati papir koji je implementira pod nazivom Tracematches.)
Sljedeći primjer objašnjava NKA M koji operira nad binarnom abecedom i koji odlučuje sadrži li ulazni niz znakova paran broj znamenki 0 ili paran broj znamenki 1.
M = gdje je
- , te
- Funkcija prijelaza može biti definirana sljedećom tablicom prijelaza:
Dijagram stanja za M jest:
M se može shvatiti kao unija dva DKA: jednog sa skupom stanja {S2, S1} i drugog sa skupom stanja {S3, S4}.
Jezik automata M može biti opisan sljedećim regularnim izrazom:
- ↑ Kiš Miroslav, Englesko-hrvatski i hrvatsko-engleski informatički rječnik, Zagreb, Naklada Ljevak, 2000., str. 660
- Michael Sipser. Introduction to the Theory of Computation. PWS, Boston. 1997. ISBN 0-534-94728-X. Section 1.2: Nondeterminism, pp.47–63.
- Siniša Srbljić. Jezični Procesori. Element, Zagreb. 2003. ISBN 953-197-129-3. Sekcija 2.1.3: Nedeterministički konačni automat (NKA), pp.29–34.